草庐IT

java - Firebase 纯 Java 客户端

全部标签

firebase - 在 Firestore 中忽略 Nil 值的最佳实践

我正在使用Golang(用于API定义的Go-Swagger)和Firestore作为我的文档存储来构建自定义网络服务。一切正常,除了在更新数据库时变得“尴尬”。我有一个解决方案,但我不相信它是最优雅的。有没有其他人遇到过这个,他们是如何解决的....问题陈述:当我写入数据库时​​,Nil值正在覆盖firebase中的现有值建议的解决方案-我的API在可选参数上有json:"omitempty"并且将传入nil值(而不是获取默认的golang值)。我计划将Struct传递到API中,并一次将一个attr填充到firestore正在使用的我的Struct中。我有性能问题,但不想将我的AP

firebase - 连接到 Firebase 存储桶

我有一个golang后端,想知道如何连接到Firebase存储以创建/删除存储桶和添加/删除文件。我可以使用Adminsdk吗?我在golang中找到了用于谷歌云存储的客户端存储库。我可以用那个吗?Firebase存储和谷歌云存储之间有什么区别? 最佳答案 我正在开发的应用通过AdminSDK连接到FirebaseStorageBuckets,但我们在Node.js中使用FirebaseFunctions。但是,看起来Go中的AdminSDK提供了相同的存储访问权限,并且在此处记录(使用Go中的示例代码):https://fireb

sockets - Golang - 为到不同服务器的多个连接扩展 websocket 客户端

我有一个websocket客户端。实际上,它比下面显示的基本代码复杂得多。我现在需要扩展此客户端代码以打开到多个服务器的连接。最终,从服务器接收到消息时需要执行的任务是相同的。处理这个问题的最佳方法是什么?正如我上面所说,接收消息时执行的实际代码比示例中显示的要复杂得多。packagemainimport("flag""log""net/url""os""os/signal""time""github.com/gorilla/websocket")varaddr=flag.String("addr","localhost:1234","httpserviceaddress")funcm

go - 如何在 grpc go 中实现非阻塞客户端?

我想在不同的服务器上运行不同的远程程序而不等待服务器的回复。当服务器完成程序时,我想在客户端回复。可以用grpcgolang做吗?我想实现一个区block链网络,我想要求不同的节点执行交易,但我不想等到一个节点提供执行输出,然后我才转移到另一个节点。换句话说,我想广播程序的执行过程,然后在执行过程中得到所有答案。我尝试了连接客户端和服务器的常用方法,但它等待服务器的响应。这会增加需要在更多节点上执行的时间。 最佳答案 你可以使用gofunc(){}()做异步任务,你可以使用同步内置包轻松控制异步任务或使用channel来控制或同步任

go - 按时间戳对 Firebase 查询进行排序似乎返回 0 个结果 [go programming language]

问题概述:我正在使用UserID==字符串查询“session”集合以获取session,这工作正常。但是当我尝试使用时间戳类型的OrderBy("DateCreated",Desc)时,我得到0个结果我尝试过的:我已经检查了数据库和我正在使用的名为“DateCreated”的属性,它是一种有效的时间戳类型。所有session数据均在随机日期范围内生成。当前结果:返回100个结果(正确)firstSessionQuery:=db.Collection("session").Where("UserID","==",uid).Documents(ctx)返回0个结果VS100个(不正确)f

不提供 http 服务时的 golang 客户端负载均衡器

作为golangn00b,我有一个go程序可以将消息读入kafka,修改它们,然后将它们发布到列表中的一个http端点。到目前为止,我们用随机数做了一些非常基本的循环cur:=rand.Int()%len(httpEndpointList)我想改进这一点,并根据端点的响应时间或类似因素增加端点的权重。我已经研究过库,但我似乎发现所有这些都是为用作使用http.Handle的中间件而编写的。例如,请参阅oxylibroundrobin在我的情况下,我不服务于HTTP请求。有什么想法可以让我在我的golang程序中实现那种更高级的客户端负载平衡吗?我想避免在我的环境中使用另一个haprox

firebase - 当路径中的数据不存在时如何使用 Go Firebase-Admin SDK 检测空结果

我正在使用以下代码从Firebase实时数据库中获取对象。typeItemstruct{titlestring`json:"title"`}varitemItemiferr:=db.NewRef("/items/itemid").Get(ctx,&item);err!=nil{log.Infof(ctx,"Anerroroccured%v",err.Error())}log.Infof(ctx,"Item%v",item)如果实时数据库中的给定路径不存在数据,SDK将不会返回错误,相反,我将在变量item中得到一个空结构。检测路径上的数据不存在的最干净/最可读的方法是什么?我已经搜索了

java - 在 Eureka Server 中,发现和注册服务/应用程序不是在 Spring 中开发的

如何在EurekaServer中发现和注册没有使用Spring(例如,在Java-JEE和Go上)构建的Web应用程序?在Spring-Boot应用程序中,很容易添加这些注释:@EnableDiscoveryClient@SpringBootApplication之前publicclassEurekaClientApp{publicstaticvoidmain(String[]args){SpringApplication.run(EurekaClientApp.class,args);}}在配置中,application.propertieseureka.client.registe

go - 可以使用 go HTTP 客户端访问 TCP 数据包详细信息吗?

我需要能够验证来自一组HTTP服务器的响应数据上的TOS/DSCP标记。给定要测试的目标URL列表,如果go中有一种方法可以生成HTTP请求,然后能够检查响应的TCP数据包详细信息以获得TOS值?此时我的假设是它可能需要创建一个套接字,然后动态生成一个包含HTTP请求负载的TCP数据包。我一直在四处搜索,看看是否有任何库可以帮助完成这项任务,但还没有找到任何具体的内容。注意:一个简单的TCP连接将无法提供足够的数据-有问题的目标服务器将根据HTTP服务器名称动态更改TOS/DSCP标记(因此本质上,单个物理服务器将根据不同的TOS标记响应vHostrequested),因此能够在实际的

firebase - 基于 Firebase 中的多个 where 子句的查询

{"movies":{"movie1":{"genre":"comedy","name":"Asgoodasitgets","lead":"JackNicholson"},"movie2":{"genre":"Horror","name":"TheShining","lead":"JackNicholson"},"movie3":{"genre":"comedy","name":"TheMask","lead":"JimCarrey"}}}我是Firebase新手。如何从上面的数据中检索结果wheregenre='comedy'ANDlead='JackNicholson'?我有哪些选